package com.xinyue.web.controller.system;

import com.xinyue.common.annotation.Log;
import com.xinyue.common.config.XinYueAdminConfig;
import com.xinyue.common.core.domain.AjaxResult;
import com.xinyue.common.enums.BusinessType;
import com.xinyue.common.utils.StringUtils;
import com.xinyue.common.utils.file.FileUploadUtils;
import com.xinyue.common.utils.file.MimeTypeUtils;
import com.xinyue.framework.web.service.TokenService;
import com.xinyue.system.base.BaseController;
import com.xinyue.system.domain.SysUser;
import com.xinyue.system.model.LoginUser;
import com.xinyue.system.service.ISysUserService;
import com.xinyue.system.utils.SecurityUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;

/**
 * 个人信息 业务处理
 *
 * @author ruoyi
 */
@RestController
@RequestMapping("/system/user/profile")
public class SysProfileController extends BaseController {

  @Autowired
  private ISysUserService userService;

  @Autowired
  private TokenService tokenService;
  @Autowired
  private XinYueAdminConfig adminConfig;

  /**
   * 个人信息
   */
  @GetMapping
  public AjaxResult profile() {
    LoginUser loginUser = getLoginUser();
    SysUser user = loginUser.getUser();
    AjaxResult ajax = AjaxResult.success(user);
    ajax.put("roleGroup", userService.selectUserRoleGroup(loginUser.getUsername()));
    ajax.put("postGroup", userService.selectUserPostGroup(loginUser.getUsername()));
    return ajax;
  }

  /**
   * 修改用户
   */
  @Log(title = "个人信息", businessType = BusinessType.UPDATE)
  @PutMapping
  public AjaxResult updateProfile(@RequestBody SysUser user) {
    LoginUser loginUser = getLoginUser();
    SysUser currentUser = loginUser.getUser();
    currentUser.setNickName(user.getNickName());
    currentUser.setEmail(user.getEmail());
    currentUser.setPhonenumber(user.getPhonenumber());
    currentUser.setSex(user.getSex());
    if (StringUtils.isNotEmpty(user.getPhonenumber()) && !userService.checkPhoneUnique(
        currentUser)) {
      return error("修改用户'" + loginUser.getUsername() + "'失败，手机号码已存在");
    }
    if (StringUtils.isNotEmpty(user.getEmail()) && !userService.checkEmailUnique(currentUser)) {
      return error("修改用户'" + loginUser.getUsername() + "'失败，邮箱账号已存在");
    }
    if (userService.updateUserProfile(currentUser) > 0) {
      // 更新缓存用户信息
      tokenService.setLoginUser(loginUser);
      return success();
    }
    return error("修改个人信息异常，请联系管理员");
  }

  /**
   * 重置密码
   */
  @Log(title = "个人信息", businessType = BusinessType.UPDATE)
  @PutMapping("/updatePwd")
  public AjaxResult updatePwd(String oldPassword, String newPassword) {
    LoginUser loginUser = getLoginUser();
    String userName = loginUser.getUsername();
    String password = loginUser.getPassword();
    if (!SecurityUtils.matchesPassword(oldPassword, password)) {
      return error("修改密码失败，旧密码错误");
    }
    if (SecurityUtils.matchesPassword(newPassword, password)) {
      return error("新密码不能与旧密码相同");
    }
    newPassword = SecurityUtils.encryptPassword(newPassword);
    if (userService.resetUserPwd(userName, newPassword) > 0) {
      // 更新缓存用户密码
      loginUser.getUser().setPassword(newPassword);
      tokenService.setLoginUser(loginUser);
      return success();
    }
    return error("修改密码异常，请联系管理员");
  }

  /**
   * 头像上传
   */
  @Log(title = "用户头像", businessType = BusinessType.UPDATE)
  @PostMapping("/avatar")
  public AjaxResult avatar(@RequestParam("avatarfile") MultipartFile file) throws Exception {
    if (!file.isEmpty()) {
      LoginUser loginUser = getLoginUser();
      String avatar = FileUploadUtils.upload(adminConfig.getAvatarPath(), file,
          MimeTypeUtils.IMAGE_EXTENSION);
      if (userService.updateUserAvatar(loginUser.getUsername(), avatar)) {
        AjaxResult ajax = AjaxResult.success();
        ajax.put("imgUrl", avatar);
        // 更新缓存用户头像
        loginUser.getUser().setAvatar(avatar);
        tokenService.setLoginUser(loginUser);
        return ajax;
      }
    }
    return error("上传图片异常，请联系管理员");
  }
}
